home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2009 February / PCWFEB09.iso / Software / Linux / Kubuntu 8.10 / kubuntu-8.10-desktop-i386.iso / casper / filesystem.squashfs / usr / share / pyshared / unohelper.py < prev    next >
Text File  |  2008-10-15  |  11KB  |  313 lines

  1. #*************************************************************************
  2. #
  3. #   OpenOffice.org - a multi-platform office productivity suite
  4. #
  5. #   $RCSfile: unohelper.py,v $
  6. #
  7. #   $Revision: 1.6 $
  8. #
  9. #   last change: $Author: kz $ $Date: 2007/10/11 11:52:50 $
  10. #
  11. #   The Contents of this file are made available subject to
  12. #   the terms of GNU Lesser General Public License Version 2.1.
  13. #
  14. #
  15. #     GNU Lesser General Public License Version 2.1
  16. #     =============================================
  17. #     Copyright 2005 by Sun Microsystems, Inc.
  18. #     901 San Antonio Road, Palo Alto, CA 94303, USA
  19. #
  20. #     This library is free software; you can redistribute it and/or
  21. #     modify it under the terms of the GNU Lesser General Public
  22. #     License version 2.1, as published by the Free Software Foundation.
  23. #
  24. #     This library is distributed in the hope that it will be useful,
  25. #     but WITHOUT ANY WARRANTY; without even the implied warranty of
  26. #     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  27. #     Lesser General Public License for more details.
  28. #
  29. #     You should have received a copy of the GNU Lesser General Public
  30. #     License along with this library; if not, write to the Free Software
  31. #     Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  32. #     MA  02111-1307  USA
  33. #
  34. #*************************************************************************
  35. import uno
  36. import pyuno
  37. import os
  38. import sys
  39.  
  40. from com.sun.star.lang import XTypeProvider, XSingleComponentFactory, XServiceInfo
  41. from com.sun.star.uno import RuntimeException, XCurrentContext
  42. from com.sun.star.beans.MethodConcept import ALL as METHOD_CONCEPT_ALL
  43. from com.sun.star.beans.PropertyConcept import ALL as PROPERTY_CONCEPT_ALL
  44.  
  45. from com.sun.star.reflection.ParamMode import \
  46.      IN as PARAM_MODE_IN, \
  47.      OUT as PARAM_MODE_OUT, \
  48.      INOUT as PARAM_MODE_INOUT
  49.  
  50. from com.sun.star.beans.PropertyAttribute import \
  51.      MAYBEVOID as PROP_ATTR_MAYBEVOID, \
  52.      BOUND as PROP_ATTR_BOUND, \
  53.      CONSTRAINED as PROP_ATTR_CONSTRAINED, \
  54.      TRANSIENT as PROP_ATTR_TRANSIENT, \
  55.      READONLY as PROP_ATTR_READONLY, \
  56.      MAYBEAMBIGUOUS as PROP_ATTR_MAYBEAMBIGUOUS, \
  57.      MAYBEDEFAULT as PROP_ATTR_MAYBEDEFAULT, \
  58.      REMOVEABLE as PROP_ATTR_REMOVEABLE
  59.  
  60. def _mode_to_str( mode ):
  61.     ret = "[]"
  62.     if mode == PARAM_MODE_INOUT:
  63.         ret = "[inout]"
  64.     elif mode == PARAM_MODE_OUT:
  65.         ret = "[out]"
  66.     elif mode == PARAM_MODE_IN:
  67.         ret = "[in]"
  68.     return ret
  69.  
  70. def _propertymode_to_str( mode ):
  71.     ret = ""
  72.     if PROP_ATTR_REMOVEABLE & mode:
  73.         ret = ret + "removeable "
  74.     if PROP_ATTR_MAYBEDEFAULT & mode:
  75.         ret = ret + "maybedefault "
  76.     if PROP_ATTR_MAYBEAMBIGUOUS & mode:
  77.         ret = ret + "maybeambigous "
  78.     if PROP_ATTR_READONLY & mode:
  79.         ret = ret + "readonly "
  80.     if PROP_ATTR_TRANSIENT & mode:
  81.         ret = ret + "tranient "
  82.     if PROP_ATTR_CONSTRAINED & mode:
  83.         ret = ret + "constrained "
  84.     if PROP_ATTR_BOUND & mode:
  85.         ret = ret + "bound "
  86.     if PROP_ATTR_MAYBEVOID & mode:
  87.         ret = ret + "maybevoid "
  88.     return ret.rstrip()
  89.     
  90. def inspect( obj , out ):
  91.     if isinstance( obj, uno.Type ) or \
  92.        isinstance( obj, uno.Char ) or \
  93.        isinstance( obj, uno.Bool ) or \
  94.        isinstance( obj, uno.ByteSequence ) or \
  95.        isinstance( obj, uno.Enum ) or \
  96.        isinstance( obj, uno.Any ):
  97.         out.write( str(obj) + "\n")
  98.         return
  99.  
  100.     ctx = uno.getComponentContext()
  101.     introspection = \
  102.          ctx.ServiceManager.createInstanceWithContext( "com.sun.star.beans.Introspection", ctx )
  103.  
  104.     out.write( "Supported services:\n" )
  105.     if hasattr( obj, "getSupportedServiceNames" ):
  106.         names = obj.getSupportedServiceNames()
  107.         for ii in names:
  108.             out.write( "  " + ii + "\n" )
  109.     else:
  110.         out.write( "  unknown\n" )
  111.  
  112.     out.write( "Interfaces:\n" )
  113.     if hasattr( obj, "getTypes" ):
  114.         interfaces = obj.getTypes()
  115.         for ii in interfaces:
  116.             out.write( "  " + ii.typeName + "\n" )
  117.     else:
  118.         out.write( "  unknown\n" )
  119.         
  120.     access = introspection.inspect( obj )
  121.     methods = access.getMethods( METHOD_CONCEPT_ALL )
  122.     out.write( "Methods:\n" )
  123.     for ii in methods:
  124.         out.write( "  " + ii.ReturnType.Name + " " + ii.Name )
  125.         args = ii.ParameterTypes
  126.         infos = ii.ParameterInfos
  127.         out.write( "( " )
  128.         for i in range( 0, len( args ) ):
  129.             if i > 0:
  130.                 out.write( ", " )
  131.             out.write( _mode_to_str( infos[i].aMode ) + " " + args[i].Name + " " + infos[i].aName )
  132.         out.write( " )\n" )
  133.  
  134.     props = access.getProperties( PROPERTY_CONCEPT_ALL )
  135.     out.write ("Properties:\n" )
  136.     for ii in props:
  137.         out.write( "  ("+_propertymode_to_str( ii.Attributes ) + ") "+ii.Type.typeName+" "+ii.Name+ "\n" )
  138.  
  139. def createSingleServiceFactory( clazz, implementationName, serviceNames ):
  140.     return _FactoryHelper_( clazz, implementationName, serviceNames )
  141.  
  142. class _ImplementationHelperEntry:
  143.       def __init__(self, ctor,serviceNames):
  144.       self.ctor = ctor
  145.       self.serviceNames = serviceNames
  146.       
  147. class ImplementationHelper:
  148.       def __init__(self):
  149.       self.impls = {}
  150.       
  151.       def addImplementation( self, ctor, implementationName, serviceNames ):
  152.           self.impls[implementationName] =  _ImplementationHelperEntry(ctor,serviceNames)
  153.       
  154.       def writeRegistryInfo( self, regKey, smgr ):
  155.           for i in self.impls.items():
  156.           keyName = "/"+ i[0] + "/UNO/SERVICES"
  157.           key = regKey.createKey( keyName )
  158.           for serviceName in i[1].serviceNames:
  159.           key.createKey( serviceName )
  160.           return 1
  161.  
  162.       def getComponentFactory( self, implementationName , regKey, smgr ):
  163.       entry = self.impls.get( implementationName, None )
  164.       if entry == None:
  165.          raise RuntimeException( implementationName + " is unknown" , None )
  166.       return createSingleServiceFactory( entry.ctor, implementationName, entry.serviceNames )
  167.  
  168.       def getSupportedServiceNames( self, implementationName ):
  169.       entry = self.impls.get( implementationName, None )
  170.       if entry == None:
  171.          raise RuntimeException( implementationName + " is unknown" , None )
  172.       return entry.serviceNames         
  173.       
  174.       def supportsService( self, implementationName, serviceName ):
  175.       entry = self.impls.get( implementationName,None )
  176.       if entry == None:
  177.          raise RuntimeException( implementationName + " is unknown", None )
  178.           return serviceName in entry.serviceNames         
  179.  
  180.       
  181. class ImplementationEntry:
  182.       def __init__(self, implName, supportedServices, clazz ):
  183.       self.implName = implName
  184.       self.supportedServices = supportedServices
  185.       self.clazz = clazz
  186.  
  187. def writeRegistryInfoHelper( smgr, regKey, seqEntries ):
  188.     for entry in seqEntries:
  189.         keyName = "/"+ entry.implName + "/UNO/SERVICES"
  190.     key = regKey.createKey( keyName )
  191.     for serviceName in entry.supportedServices:
  192.         key.createKey( serviceName )
  193.  
  194. def systemPathToFileUrl( systemPath ):
  195.     "returns a file-url for the given system path"
  196.     return pyuno.systemPathToFileUrl( systemPath )
  197.  
  198. def fileUrlToSystemPath( url ):
  199.     "returns a system path (determined by the system, the python interpreter is running on)"
  200.     return pyuno.fileUrlToSystemPath( url )
  201.  
  202. def absolutize( path, relativeUrl ):
  203.     "returns an absolute file url from the given urls"
  204.     return pyuno.absolutize( path, relativeUrl )
  205.         
  206. def getComponentFactoryHelper( implementationName, smgr, regKey, seqEntries ):
  207.     for x in seqEntries:
  208.     if x.implName == implementationName:
  209.        return createSingleServiceFactory( x.clazz, implementationName, x.supportedServices )
  210.  
  211. def addComponentsToContext( toBeExtendedContext, contextRuntime, componentUrls, loaderName ):
  212.     smgr = contextRuntime.ServiceManager
  213.     loader = smgr.createInstanceWithContext( loaderName, contextRuntime )
  214.     implReg = smgr.createInstanceWithContext( "com.sun.star.registry.ImplementationRegistration",contextRuntime)
  215.  
  216.     isWin = os.name == 'nt' or os.name == 'dos'
  217.     isMac = sys.platform == 'darwin'
  218.     #   create a temporary registry
  219.     for componentUrl in componentUrls:
  220.         reg = smgr.createInstanceWithContext( "com.sun.star.registry.SimpleRegistry", contextRuntime )
  221.     reg.open( "", 0, 1 )
  222.         if not isWin and componentUrl.endswith( ".uno" ):  # still allow platform independent naming
  223.             if isMac:
  224.                componentUrl = componentUrl + ".dylib"
  225.             else:
  226.                componentUrl = componentUrl + ".so"
  227.  
  228.     implReg.registerImplementation( loaderName,componentUrl, reg )
  229.     rootKey = reg.getRootKey()
  230.     implementationKey = rootKey.openKey( "IMPLEMENTATIONS" )
  231.     implNames = implementationKey.getKeyNames()
  232.     extSMGR = toBeExtendedContext.ServiceManager
  233.     for x in implNames:
  234.         fac = loader.activate( max(x.split("/")),"",componentUrl,rootKey)
  235.         extSMGR.insert( fac )
  236.     reg.close()
  237.                 
  238. # never shrinks !
  239. _g_typeTable = {}
  240. def _unohelper_getHandle( self):
  241.    ret = None
  242.    if _g_typeTable.has_key( self.__class__ ):
  243.      ret = _g_typeTable[self.__class__]
  244.    else:
  245.      names = {}
  246.      traverse = list(self.__class__.__bases__)
  247.      while len( traverse ) > 0:
  248.          item = traverse.pop()
  249.          bases = item.__bases__
  250.          if uno.isInterface( item ):
  251.              names[item.__pyunointerface__] = None
  252.          elif len(bases) > 0:
  253.              # the "else if", because we only need the most derived interface
  254.              traverse = traverse + list(bases)#
  255.  
  256.      lst = names.keys()
  257.      types = []
  258.      for x in lst:
  259.          t = uno.getTypeByName( x )
  260.          types.append( t )
  261.          
  262.      ret = tuple(types) , uno.generateUuid()
  263.      _g_typeTable[self.__class__] = ret
  264.    return ret
  265.   
  266. class Base(XTypeProvider):
  267.       def getTypes( self ):
  268.       return _unohelper_getHandle( self )[0]
  269.       def getImplementationId(self):
  270.       return _unohelper_getHandle( self )[1]
  271.  
  272. class CurrentContext(XCurrentContext, Base ):
  273.     """a current context implementation, which first does a lookup in the given
  274.        hashmap and if the key cannot be found, it delegates to the predecessor
  275.        if available
  276.     """
  277.     def __init__( self, oldContext, hashMap ):
  278.         self.hashMap = hashMap
  279.         self.oldContext = oldContext
  280.  
  281.     def getValueByName( self, name ):
  282.         if name in self.hashMap:
  283.             return self.hashMap[name]
  284.         elif self.oldContext != None:
  285.             return self.oldContext.getValueByName( name )
  286.         else:
  287.             return None
  288.         
  289. # -------------------------------------------------
  290. # implementation details
  291. # -------------------------------------------------
  292. class _FactoryHelper_( XSingleComponentFactory, XServiceInfo, Base ):
  293.       def __init__( self, clazz, implementationName, serviceNames ):
  294.       self.clazz = clazz
  295.       self.implementationName = implementationName
  296.       self.serviceNames = serviceNames
  297.       
  298.       def getImplementationName( self ):
  299.       return self.implementationName
  300.  
  301.       def supportsService( self, ServiceName ):
  302.       return ServiceName in self.serviceNames
  303.  
  304.       def getSupportedServiceNames( self ):
  305.       return self.serviceNames
  306.  
  307.       def createInstanceWithContext( self, context ):
  308.       return self.clazz( context )
  309.           
  310.       def createInstanceWithArgumentsAndContext( self, args, context ):
  311.       return self.clazz( context, *args )
  312.       
  313.